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INTRODUCTION 

The subject of this course is the Logical Structure of Digital Com- 
puters.. By "computer logic" one means the set of rules which the 
computer follows in carrying out its operations., Logical structure 
is to be distinguished from physical structure . The electronic 
components, wires , motors, and other hardware, comprising the 
physical structure of the computer, do no more than mechanize the 
operating rules defining the logical structure of the computer. It 
is completely irrelevant to the logic that the computer is built of 
vacuum tubes, or relays, or paper, as long as the rules are properly 
represented and followed <, 

The digital computer is essentially a symbol-manipulating machine . 
It accepts a set of symbols defining a problem to be solved and the 
data on which to operate . It then performs various operations on 
these symbols according to the rules defining its logical structure, 
and thereby produces a new set of symbols which comprise the solu- 
tion to the problem. The rules thus take the form of a set of 
statements describing the manner in which certain symbols are to be 
replaced with new symbols . (Consider, for example, a particular 
sequence of five symbols • One useful rule in a computer dealing 
with this sequence would be? "If the first symbol is a 8 1?, the 
second °+', the third 8 1 S , the fourth 8 = ! , and the fifth 'x', then 
replace the symbol 8 x 8 with the symbol *2'.") 



THE TURING MACHINE 

A simple abstract model of the general symbol- manipulation process 
(and; therefore, of digital computer logical structure) was formu- 
lated by the British mathematician, Turing! as a conceptual aid in 
proving certain results in mathematical logic. He defined a class 
of symbol processing mechanisms which he called simply "automatic 
machines," but which are now generally known as "Turing machines." 

The elements of the Turing machine are illustrated below: 
T 



s 2 i s il S 7T I ! 1 \ 



M 



~A. Mo Turing? On Computable Numbers, with an Application to the 
Entscheidungs Problem, Proc . Lond. Math , Soc, series 2, V24, 
p P o 230-265, 1936o 
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A machine, M, having a finite number of internal configurations or 
states operates on an infinitely long tape, T, which is divided 
into cells. Each cell is capable of bearing one symbol from a 
specified, finite set of symbols, So, S^, S^ * * * Sq, e.g., the 
alphabet, the digits, etc. The machine deals with one cell at a 
time (called the scanned cell) and can read the symbol in this cell 
and write a new symbol in its place, or move to the next cell to 
the right or to the left. 

An operation is carried out concurrently with a Jump from one mach- 
ine state to another. This action is completely determined by the 
current state of the machine and the currently scanned symbol. Each 
move results in a new configuration of machine and tape in which the 
scanned symbol and machine state determine the next move, and so on. 

A notation will now be described and some examples of Turing machines 
presented. This material will differ from that in Turing's original 
presentation, but the essential features are retained. 

The operations to be discussed ares 

1) Replace the scanned symbol, Si, with the symbol Sj, 
abbreviated j 

Si : Sj 

where i and j may have any particular values 0, 1, 
2, • • • n. The symbol So will represent blank tape 
to complete the description. 

2) If the scanned symbol is Si, move to the next cell 
on the rights 

Si % R 

3) If the scanned symbol is Si, move to the next cell 
on the lefts 

Si t L 

These operations can be abbreviated : 

T k = print St ' k - 0, 1, • • • n 

Si : Tjt ^ 3?k = move "R" k = n + 1 

. Tfe = move M L" k = n + 2 

The rules by which the machine operates are then formulated in terms 
of these operations and the internal states of the machine. Each 
rule will be of the form: 
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If the machine is in state p (p = 1, 2, • • ♦ M) 
and the scanned symbol is Si (i = 0, 1, * • • N) 
then carry out operation T^ (k = 0, 1, • • • N + 2) 

i and jump to state q (q = 1, 2, * • • M) 

j 

which will be abbreviated to the quadruple: 

(p. Si : T k , q) 

For example, the quadruple (3, x : R, lk) means "If the machine is 
in state 3 an<i the scanned symbol is x, move to the next cell on the 
right and jump to state l^." 

The logical structure of the machine is thus specified by a finite 
set of quadruples of the above form. 

The ordered pair of symbols p, Si will be called a determi nant , 
since it determines the subsequent move of the machine according to 
the remaining terms in the quadruple . To be consistent, the require- 
ment is imposed that no two quadruples describing a given machine 
can have the same determinant. 

The logical structure of a Turing machine may be represented conven- 
iently as a network in which each node corresponds to a state of 
the machine and each directed branch between nodes corresponds to 
a jump between states. The branch is labeled with the operation 
which occurs during the jump. For example, the network 






y .' ft 




x :V 



corresponds to the set of three quadruples 

(1, x : R, 2) 
(2, x : y, 2) 

(2, y : R, 1) 

A drawing of the network for a given machine is variously called a 
state diagram or transition diagram. Two conventions which simplify 
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the drawing of transition diagrams for processes involving a large 
number of symbols So, S^, S%, • • • Sn are the following: 

a) If all branches from a given state, p, lead to state q,, 
and involve the same operation, T& 



So.* 71 




then the diagram may be abbreviated to 

— s— <?) 

b) If all branches except the one for a particular scanned 
symbol, Si, lead from state p to state q, and involve 
the same operation, Tjj 



5©17* 




then the diagram may be abbreviated to 




where S^ is read "not S^." 



A few examples of Turing machines will now be given to illustrate 
the preceding definitions and concepts. 
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Example 1 



Given a tape on which the symbols So, S±, S2, ° ' • S n appear 
in any order and number. The machine starts in state 1 scan- 
ning any cell to the left of a cell holding the symbol, Si 



T 



Sq s s 3 s 7 s k 



S]_ Sq S]_ S 



The machine is to "hunt" for the first cell to the right, 
which holds S^ and jump to state 2 when it is scanning this 
cell* The transition diagram is 



Sil$ 




S, '-S, 



<D 



The machine remains in state 1 and scans the next cell on 
the right until S]_ is founds whereupon it jumps to state 12 
with no change of symbol on the scanned cell. 



Example 2 



Consider a process of simple cryptographic encoding. Letters 
of the alphabet are to be scrambled according to the code 



•o 
•r 
•P 



e.g., the word "cab" becomes 



'por% 



etc. The message to be 



encoded is printed on the tape with an arbitrary number of 
spaces between words. 



T 



n 



w 



h 
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The machine starts in state 1, scanning the indicated cell. 
Its diagram is 




The symbol Sq represents blank tape. The machine continues 
indefinitely, changing letters of the message to their equiva- 
lent code value. 



Example 3 



A block of five cells, each holding the digit 0, is separated 
from the rest of the tape by the symbol E on the left and C 
on the right. 



E 















The machine starts in state 1, scanning a cell to the right 
of C. It is to print in succession the 5-&igit decimal 
numbers from to 99*999 on the marked block of cells, reset 
them to 0, and then jump to state 5» Its diagram is 
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The machine finds the first digit following symbol C and 
jumps to state 2. If this digit is not 9> it is replaced 
with the next larger digit and the machine jumps to state 3» 
In state 3; the machine moves right until it finds C and 
"backs up one cell, jumping hack to state 2. When the digit 
is 9, it is replaced with and the machine jumps to state 
h and moves left one cell (corresponding to a "carry" from 
one digit position to the next), returning to state 2 again. 
Clearly, this process results in the printing of the required 
sequence of numbers up to 99 #999- At this point, the re- 
peated sequence of transitions (2, 9 : 0; 4 (^ : L, 2) 
resets the five cells to and the process terminates with 
(2, E : E, 5). , 



Example k 



Consider a tape marked with A, 1, 0, and x in the following 
manner i 



T 



A 



x 



x 







X 



X 



etc. 



The l's and s s are intermixed with x's to the right of A 
in an arbitrary way. The machine starts in state 1, scanning 
a cell to the left of A, and is to compact the sequence of l's 
and 0's into a block following A. The order of the l's and 
0's is to be retained. The diagram is 




In state 1, the machine finds the first symbol to the right 
of A and jumps to 2. In state 2, the machine skips over 
cells holding x's and finds the nearest or 1, replaces it 
with an x and jumps to state 6 or 3* respectively. In the 
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case illustrated, the nearest non-x symbol is a 1, and the 
machine will go to state 3» In state 3> the machine finds 
the leftmost x, jumps to k, prints a 1, and moves to the 
right, returning to state 2 via 5. Note that in taking 
either the upper or lower branch, (2, 1 : x, 3) or 

(2, : x, 6) , the machine in effect "remembers" that 
the last symbol scanned was a 1 or 0, respectively. The 
reader should verify that the tape illustrated becomes: 



a|i|o|i|x|x1x|x)x| 



T 



It is possible to restrict the Turing machine to two symbols, 
and 1, without loss of generality. 

Consider a problem which is expressed in terms of four symbols: 
8q, S^, &Z* ®3* These can be encoded into groups of l's and 0's 
in many ways. For example: 



S = 000 
Si - 001 

52 « 010 

53 = 100 

(1) 



s = 00 
s x « 01 
s 2 - 10 

S3 all 

(2) 



Case (2) will be discussed in more detail. The tape is divided 
into groups of two cells each: 















1 1 




So Si S 2 »3 

Then consider a section of the transition diagram of a machine 
dealing with Sq, Si, S2, S3 which is of the form 
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Phis is equivalent to the following in which only and 1 are used: 




Similarly, a change of symbol, say (l, S]_ : Sg^) can "be represented 
as? 




0-^MD 



Note that the interpretation of the sequence of l's and O's depends 
on the direction of travel. This dependence could be eliminated 
by using a symmetrical code: 



so 


= 000 


Si 


= 010 


S2 


= 101 


S3 


= 111 



We have now shown that the operations of any Turing machine can be 
reduced to the set 

{print 
print 1 
move right one cell 
move left one cell 

This can be reduced still further. The only possible symbol -printing 
situations ares 
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: l) 

1 : 0) 

: 0} 

1 : lj 

The first two cases involve a change of information on the tape) 
the second two do not. We can define an operation "complement,' 1 
abbreviated f, C% to replace the two print operations « The cases 
involving no change of symbol are replaced with two complement 
operations done in sequence: 

Thus, the set of Turing machine operations reduces to: 



} 



This can he reduced again to any of the three sets: 

(1) TcL complement and move left 
(^ R move right 

(2) f L move left 

\CR complement and move right 

(3) j CL complement and move left 
^CR complement and move right 

The proofs for (l) and (2) reduce to showing that "CL" can be 
broken into "C" and "L": 

is the equivalent of 

and 

is the equivalent of 
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The other possible actions on and 1 for cases (l) and (2) are 
proved in a similar manner. 

Case (3) requires a different arrangement of symbols on the tape. 
Alternate cells are used to hold the symbols of the problem. The 
cells in between aid in "phasing" the complementing, but hold no 
significant information: 











The equivalent forms are: 



.O^sVSHt-© 



(D^MD 



0J>i£S^«^(j^^ => Q^C0 



The other forms can be obtained directly from these. 
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PROBLEMS 



lol) A Turing machine tape is marked in the following manner: 



d-il a t l|dk I <3-l-| <3m 



Symbol "P" marks the beginning of a block of 5 different 
decimal digits, d^, dj, d^, di, a^. (e«g«, 7 9 3 *0» 

Describe (draw a state-and -trans it ion diagram of ) a machine 
which -will rearrange the digits in descending order on the 
5 cells following "P" and move on to the right when finished. 
Any additional symbols and cells may be used in the process 
providing they are erased upon completion. The machine is 
to start on any cell to the left of "P". 



1.2) Restate problem 1.1 in terms of a tape on which only the 

symbols "So" and "Si" appear, (invent a suitable code for 
the symbols "P", blank, 0, 1, • • • 9, etc., and describe 
the initial tape configuration). Redraw the state-and- 
transition diagram accordingly, using only the operations 
"complement" (change So to Si or Si to So), "move right", 
and "move left", abbreviated "C","R", and "L", respectively. 



3) Hon-erasable tape can be defined as tape on which it is 

possible to write a symbol in a given cell only if the cell 
is blank. Show that it is possible for any Turing machine 
to use non-erasable tape. 
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THE UNIVERSAL TURING MACHINE 

Preliminary Remarks 

We have seen that a very general class of Turing machines can he 
defined which use a single tape on which only the symbols "0" or 
"1" appear in any cell ("0" corresponding to blank tape) and which 
perform only the operations "print 0," "print 1," "move right one 
cell," and "move left one cell." For convenience in subsequent 
reference, we will call these machines "Class A Turing machines" 
to distinguish them from other machines which use more symbols, 
different operations, more tapes, etc Within a given class one 
might measure the complexity of a particular machine by the number 
of its internal states or, perhaps better, by the number of quad- 
ruples required to describe its logical structure. Thus, a 100- 
quadruple Class A Turing machine would be more complicated than a 
10-quadruple Class A Turing machine « 

It seems reasonable to attempt to relate a machine "s complexity to 
its capability. For example, it is possible to combine a machine, 
M]_, which is capable of counting, with a machine, M2, which is 
capable of ordering a set of numbers, and thereby obtain a more 
complicated machine, Mo, which is capable of both ordering and 
counting • It might be supposed that it is always possible to in- 
crease the generality of a machine by increasing its complexity in 
this way« The fact is, however, that there is a critical complexity 
beyond which no further increase in generality can be guaranteed! 
That is, at a certain level of complexity it becomes possible to de- 
sign a Turing machine which is universal in the sense that it can 
perform any calculation which any other Turing machine can perform , 
even if the other machine is more complicated than the universal 
machine . The universal Turing machine achieves this generality by 
having the ability to simulate any machine whose calculation it is 
required to duplicate • The tape of the simulated machine appears 
as a designated sequence of cells on the tape of the universal 
machine o We will consider these points in more detail later. 

Quadruple Manipulation 

The simulation is itself a symbol manipulation process in which the 
symbols represent the set of quadruples describing the simulated 
machine o As an example of the manipulation of quadruples, consider 
the following simple Class A machine and the set of quadruples de- 
scribing its logical structures 
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D 







M 




(1, : 1, 1) 

(1, 1 : R, 2) 

(2, 1;; 0, 2) 

(2, : R, 1) 



This machine, starting in state 1, will print the sequence 10101010.. 
.... o Its operation will now he described in terms of the quadruples 
and scanned symbols s 

Define active quadruple to be that quadruple which describes 
the action of the machine at any given point in the process. 
^ ie o^lve determinant is then the determinant found in j 
the active quadruple (see page 3). The first term of the 
active quadruple will be called the initial state , and the 
last term, the final state . The second term of the active 
quadruple is, of course, the scanned symbol, and the third 
term is the specified operation., 

In the illustration, if the machine is in state 1, the ac- 
tive quadruple is the second one in the list, namely: 

(1, 1 : R, 2) 

The machine will move one cell to the right and jump to the 
final state 2 . State 2 thus becomes the initial state of 
the next machine action and the new scanned symbol is a "1". 
Therefore, the next active determinant will bes 

2, 1 

The next active quadruple can be found by again examining 
the list of quadruples and finding the quadruple which 
starts with the determinant 2, 1* In this case, it is the 
third determinants 

(2, 1 : 0, 2) 



The machine will print a "0" and jump to the final state 2. 
The scanned symbol is now ,1 0" and the next initial state is 2; 



6M- 3938* Supplement 1 Page 15 

thus, the next active determinant will be 

2, 
and the next active quadruple is found to be 

(2, ; R, 1) 

etc 

This example illustrates the use of the set of quadruples in 
describing a sequence of machine actions. 

General Description of the Universal Turing Machine 

The basic simulation process can be represented in the following 
ways 



A. Given the active determinant, 
find the active quadruple » 



B. Garry out the specified 
operation . 



Co Form the next active deter- 
minant from the new scanned 
symbol and the new initial 
state (the previous final 

Sfa&T>6 a) a 



It is, of course, necessary to start this sequence with the first 
active determinant at A. 

The Universal Turing Machine, UM, will be designed to carry out the 
above steps A, B, and C for any list of quadruples describing a 
given simulated machine, SM, which will be encoded in a suitable 
manner and printed on the universal machine tape, UMT. As we men- 
tioned earlier, this tape will also hold a sequence of cells 
which correspond to the cells of the simulated machine tape, SMT. 
It will also require cells on which to print the active determin- 
ant symbols, and cells to mark significant points on the tape, 
e»go, the SMT scanned cello 
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r 



■~l 
I! 



SMT 



j_ Simulated Machine ! 



5 



UMT 



Universal Machine 

Before UM begins its calculation, the quadruples defining SM are 
printed on UMT^ the cells on UMT corresponding to SMT are marked 
to match the initial configuration of SMT, and the first active 
determinant is printed on UMT. UM is started in a specified 
initial state scanning a specified cell on UMT. It then carries 
out steps A P B, and C without end and prints the results of SM's 
calculation on the designated UMT cells corresponding to SMT. 
It is assumed that the set of symbols used by SM is included 
within the set of symbols used by UM. 

Detailed Description of a Class A Universal Turing Machine 

The general description of the previous section will now be 
related to a particular Class A Universal Turing Machine. It is 
seen that the first problem is that of finding a suitable code 
using the symbols and 1 to represent quadruples, determinants, 
etc. The coding scheme presented here is the work of E. F. Moore 
who employed it in a description of a 3""tap° universal machine 2 . 
The second problem is that of finding a suitable arrangement of 
the symbols on the universal machine tape. Finally, a descrip- 
tion of the universal machine itself must be developed. 

Consider first the coding of a Class A machine quadruple 

(r, Si : T&js). Each determinant must be one of the two forms: 



J E. Fo Moore; A Simplified Universal Turing Machine , Bell Tele - 
phone System Monograph 2098 , presented at the Meeting of the 
Association for Computing Machinery, Toronto, Ganada, Sept. 8, 
1952. 
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r, 
or 

r, 1 

where r takes on any; integral value 1, ' 2, '•"•'"• 'M (for an M-state 
machine)* The specified operation, T&, is any one of the four 
forms : 



1 

R. 

L 

and finally, the final state, s, is an integer from 1 to M. 
The scheme proposed "by Moore is the following i 
Determinant s , 

Code r, as a block of 3r + 1 successive l's 

" r, 1 " " " " 3r + 2 " l's 



immediately following determinant, 
ii it n 



Operation: 








Code 





SLS 





« 


1 


as 


00 


»! 


R 


as 


000 


ft 


L 


as 


0000 


Final States 







Code s as a block of 3s successive l's immediately following 
the operation. 

For example, the quadruple (l, : 1, l) would become: 

111100111 
and the quadruple (l, 1 s R, 2) would becomes 

11111000111111 

A list of quadruples is coded by stringing together in any order the 
codes of member quadruples, separating one quadruple from the next by 
at least one 0. For example, the machine described on page lk 

(1, : 1, 1) 

(1, 1 ; R, 2) 

(2, : R, 1) 

(2, 1 f 0, 2) 
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is completely (although not uniquely) coded by the sequence; 

• ' • 000011110011101111111101111110001111111000111001111100011111100 • • • 

Notice that any block of ones in this sequence has a unique interpre- 
tation, e.g., a block of N ones represents a final state only if N is 
divisible by 3, etc. A block of zeros following a determinant repre- 
sents an operationi a block of zeros following a final state is simply 
a separation. 

We now proceed to describe the arrangement of symbols on the universal 
machine tape, UMT. UMT will need to be endless only on the right. 
The class of machines which the universal machine will simulate will 
also use tapes which are endless only on the right. This causes no 
restriction in the generality of these machines over that of doubly 
endless tape machines (see problem 2.1), 

UMT will be divided into groups of 7 cells each. The quadruple list, 
active determinant, SMT cells, and various marking cells will be 
interleaved on UMT in the following manner; 



|Ei 


q.i Qi 


E 2 


IX Q 2 


E 3 


<1 3 Q 3 


E k 


1' 




! 








\ 



*L Dl 



t x T-L 



&2 D ? 



t 2 T 2 



d 3 D 3 



V T 3 



UMT 
The E cells are used to mark the end of the tape (only Ei holds a 



T 



These are not changed 



:) 



The D cells hold the active determinant. 
The Q cells hold the list of quadruples. 
The T cells correspond to the cells of the simulated machine tape. 

The cells labeled d, q, and t are used to mark the following D, Q, and 
T cells, respectively. Only one cell of each will hold a "l" at any 
given point in the calculation. For example, a "1" in to indicates 
that To would be the scanned cell on SMT. The use of these marker 
cells will become clear later. 



To go from cell Q^ to Q^+l for example, it is necessary to slip over 
the intervening 6 cells. This process is diagrammed; 



R 



R 



CH^-O 



R 



o 



R 



O 



R 



O 



R 



O^MS) 



and will be abbreviated: 



R7 

Q >© 
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The process of locating the end of the tape will now be described. 
Suppose that UM is scanning some Q cell and is to find the cell E]_ 
if the scanned symbol is "1". The diagram iss. 




The letters Q and E below the state node in this diagram indicate 
which "phase" of the 7 tape phases the machine will end in after the 
transition to that state « The machine starts in state "a" scanning 
a Q cell j (i.e., in Q-phase). If the scanned symbol is a "1", the 
machine moves 3 cells to the right (to the nearest E cell) and jumps 
to state "b" » Now in E phase , the machine scans successive E cells 
to the left until a "1" is found, which occurs on E^_ at the end of 
the tape. 



UM will start in state 1 scanning Ei„ The quadruple list for SM is 
printed on the Q, cells beginning with Qi and q.-j_ holds a "1" (qj. marks 
Q^)o The first active determinant is printed on Di, D2> D3, etc., 
and &1 holds a "1" (dj_ marks D±)» Finally, the T cells are marked 
according to SMT and the initial simulated scanned cell T s will be 
marked (t s holds a M l"). 

It, will be noted that UM must move to the end of UMT before search- 
ing for a "1" on any marker cell in order to guarantee that the 
marked cell will not be missed . 

Parts A^ B, and C of the operation of one particular Glass A Univer- 
sal Turing Machine will be described separately on the following 
pages o 
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A= Given the active determinant, find the active quadruple. 




Mark next Q cell 



to state 26 



The next D cell is marked (a "1" is printed in the associated d cell) 
in states 2 to k and the previously marked D cell is examined (state 5)» 
If it holds a "1", I3M check? the currently marked Q cell (and marks the 
next Q cell) in state 10 ano. if it holds a "1% prepares to compare the 
next D and Q cells by returning to state 1. If the D and Q blocks are 
of unequal length, 1M marks the next Q "block of 1*8^ marks the "beginning 
of the active determinant again, and starts the comparison with the new 
Q block by returning to state 1. When both D and Q cells hold 0"s con- 
currently, the active quadruple has been found and WL jumps to state 26 ; 
to begin part B* 
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Bo Carry out the specified operation. 



o*.i7 ot%* \-o 




<J*R 



(one 0) Print on SMT 




Q ^E t — T 

* (two fl s) Print 1 on SMT 




t t 

Of 

<3 



ee B s) Move R on SMT 




D-L 7 0-R' 




E ~t t 

(four tt s) Move L on SMT 



to state **3 



The active quadruple has "been located and UM determines which SM 
operation is specified by counting the number of successive O's in 
the operation code* If one 0, UM finds the scanned cell on SMT and 
prints a "0"| if two 0°s, a "1"| if three 0°s, UM marks the T cell 
on the right of the currently marked T cellj if four O's, UM marks the 
T cell on the left of the currently marked T cell. UM then returns 
to the end of the tape and moves on to -?art C. 
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Co Form the next active determinant from the new scanned symbol 
and the new initial state (the previous final state) . 



o.t-' 




ML' TT^ M) £i 



Erase old determinant 




e — t T 
Examine scanned 
symbol on SMI! 



one 1 

"Add" l 8 s to new 
active determinant 



\:r' 



o-.C 



o-[ 



OIR' 




05R 7 



0-L 7 



Extend D block one cell 



Copy final state onto D 
cells 



Mark final- state block 





E — % — <V 

Examine next Q cell 



r q — e "~V, v ~' < li to state 1 
Mark Di and Q,-j_ 



The old active determinant is erased (states k-3 to k6) and the current 
scanned symbol on SMT is examined. If it is a "0", a "1" is printed 
on Di to start the next active determinant | if the scanned cell on SffiH 
holds a "1% then a "1" is printed on both Di and Dg» UM then combines 
the block of "l's" which code the final state of the active quadruple 
with the one or two l 9 s now on the initial D cellSj, thus forming the 
new active determinant • Dj_ and Q^ are marked (l°s printed on di and 
q,l) and 13M returns to state 1 to repeat A, B, and C for the next simu- 
lated transition. 
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PROBLEMS 



2.1 Show that any problem which can he solved by a Turing machine 
using doubly infinite tape (infinitely long in both directions) 
can also be solved by a Turing machine using singlj infinite 
tape. 



2o2 Consider the class of Turing machines which use only the 
symbols "0" and "1" and which perform only the operations 
"print 0", "print 1", "move right one", "move left one", 
abbreviated 0, 1, R, L, respectively. 

How many one-state machines of this class are there? Two-state? 
N-state? 



2.3 A Turing machine calculation which never uses more than a 

finite length of tape might be called limited j otherwise non - 
limited . (For example, the machine (1,0:0,1) (l,l:R,l) per- 
forms a limited calculation if the tape holds a "0" to the 
right of the scanned cell.) 

Write the set of quadruples for each one-state machine of the 
class defined in 2.2 which is non - limited for all possible 
arrangements of symbols on the tape. 



2. if Design a Universal Turing Machine using as few internal states 
as possible. The design may use any finite number of symbols 
to aid in reducing the number of states required. Make a count 
of the number of states and the number of quadruples. 



6m~393£U Supplement 2 



Division 6 - Lincoln Laboratory 
Massachusetts Institute of Technology- 
Lexington 73 * Massachusetts 



SUBJECTS THE LOGICAL STRUCTURE OF DIGITAL COMPUTERS 
Boolean Algebra 

Tbs Class Registrants 

Abstracts tos JVC. Proctor j, Co Wo Farr 

fcroms W» A* Clark 

Kates 2 November 1955 



Abstracts The symbol -printing operations in a Glass A Turing 
machine can be described in terms of the tape cells 
themselves For example ^ a machine which performs 
the sequence w If cell A holds "1" or if cell B holds 
w 0", print "1" on cell C" is described by the 



(A 1 or B^sC 1 

The manipulative aspects of this notation can he 
exploited in demonstrating that the rules for 
printing symbols define a Boolean Algehrao 
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The Class A Universal Turing Machine described on the preceding 
pages provides us with one value for the critical complexity dis- 
cussed earlier . A count of transitions shows that about 800 
quadruples are required to describe this machine*, Other universal 
machines using more symbols and fewer internal states have been 
designed (see also problem 2 4)| Shannon has shown^ that it is pos- 
sible to design a two-state universal machine (and: impossible to 
design a one^state universal machine) by using a large enough 
number of symbols o 

Variations oy t he Turing Machine Theme 

There are many possible variations to the Turing machine concept. 
In the example presented earlier, the machine operated on a linear 
array of symbols printed on an infinitely long tape* Another class 
of machine might be defined which operates on a two-dimensional 
array of symbols printed on an infinite plane » 



2 
+ a b v- ', 

* 1 2 t 




C / * < 

4 - - d 

a. 2 4 


a 2 


p 11 O Q 

a. 2 ' 


f OS 



The operations' of this machine would include "'move right," 
left j** **move up/ 8 and ?5 move down.,* 8 Extension of these idee 

n~dimens£onal arrays readily follows o 



A three-tape Turing machine was mentioned earlier^" * In this case^ 
the machine deals with three separate linear arrays scanning three. 
cells simultaneously but operating on only one tape at a time. The 
transitions are described as sets of sextuples rather than quad- 
ruples^ each determinant consisting ©f the initial state and the 
tlsree scanned.: symbols « Again , extension to machines using more 
tapes or several n-dimensional arrays is possible „ 

Von Neumann has suggested a parts -manipulating machine analogous 



Vc E* Shannon and others? "Automata Studies/ 
sity Press (to be published shortly,,) 



Princeton Univer- 



*t. 



P. Moores Op. cit. 
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to the Taring symbol -manipulating machine • This machine would op- 
erate in an enrolment containing hardware of various kinds such as 
nuts ; bolts , wire; vacuum tubes s etco^ and would construct another 
machine from these parts • Again ^ it is possible to design a uni- 
versal constructing machine capable of constructing anything that 
any other constructing machine can construct e A case of particular 
interest is that of a machine which constructs a copy of itself. 
With the current trend toward automation, some of these ideas are 
being applied in practical situations « 

Summary Remarks' 

Before moving on to further discussion of the Turing machine and 
its relation to other topics ^ let us list some of the items which 

have been introduced in the preceding pages? 



lo 


Logical structure 


6* 


Coding 


2o 


Operating rules 


To 


Machine complexity 


3o 


Stable states 


8 d 


Simulation 


ko 


Transitions 


9* 


Universality 


5o 


Symbol manipulation 







These are all. items will will be discussed in more detail during 
the remainder of the course <> It is interesting that the concep- 
tually simple Turing machine serves to introduce so many of the 
basic ideas in the subject of digital computers „ 



BOOLEAN ALGEBRA 

We now proceed to develop a manipulative notation which enables 
us to describe the action of two-symbol machines in terms of the 

cells themselves . This will lead to a kind of symbol-printing 

algebra which will be shown to have the properties of Boolean 
algebra o 

Consider the following simple Class A Turing machine which operates 
on cells labeled A 5 B* and Co 



A B C 
10 
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for which the transition diagram is 




The machine prints "1" on C if A and B hold the same symbol and 
prints a n n on C if A and B hold different symbols <» The symbol 
finally appearing in cell G depends on the symbols in A and Bo 
There are^ of course, several kinds of dependence relations pos- 
sible^ and the machine illustrated mechanizes only one of these 
relations* A word description of the illustrated process in terms 
of basic Turing machine operations would consist of the following 
pair of statements s 

1. If cell A holds "1" and cell B holds "1", 
or if cell A holds "0 W and cell B holds n n , 
then print n l n on cell Co 

2, If cell A holds "I s8 and cell B holds n 0" , 
or if cell A holds "0" and cell B holds "1% 

then print n n on cell Co 

A notation which simplifies this description is one which employs 

superscripts to denote the symbol held in a given cell; 

A will mean " there is a °0 8 in cell A** 
and A will mean n there is a "1" in cell A" 
Then we might agree that 

A°s will mean "if there is a °0 8 in cell A fl 

and sC 1 will mean "print a »1» in cell C" 

With these abbreviated forms 9 the statements describing the action 
of the illustrated machine becomes 
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(A 1 and B 1 or A° and B°)sC l ) 
(A° and B 1 or A 1 and BO)sCO J 



Page 27 



The remaining simplification involves replacing "and" and "or" 
with shorter symbols o W@ will choose "«" to replace "and" and 
**+ w to replace "or D " With these changes the statements "becomes 



(A 1 • B* + A° • BO^C 1 I 
(A° * B 1 + A 1 • B°)gC° J 



and the transition diagram can be redrawn in the forms 




which is considerably simpler and more compact than the original 
diagram » 

It is interesting to note that in this new description the opera- 
tions "R" and "£" do not appear* It is no longer a requirement 
that the cells k $ B, and C he adjacent cells in a linear array. 
In fact, the new transition diagram equally well describes the 
action of a discrete -state machine which deals with several inde- 
pendent cells simultaneous lys 



.£. 







\-T 










We will return to this idea later . 

Table of Combinations 

The possible outcomes and the corresponding conditions of A and B 
can be represented conveniently in a table. On the left are listed 
all combinations of symbols found in A and B, and on the right the 
resulting symbol in Cs 
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A 


B 


C 








1 





1 





1 








1 


1 


1 



Thus , the first line of the table corresponds to A°*B°;C , etc. 
The number of lines , k, in such a table is given by fc*2B, where 
n is the number of cells determining the symbol to be printed. 
The number of different tables is 2&, i.e.,- 

2 2 «s number of functionally different machines 
which print "l" or "0"' depending on the 
symbols held in n cells • 

It should be noted that directions for printing only the l's are 
sufficient to determine the complete table* Thus, it is sufficient 
to describe the illustrated machine bys 

(A 1 "B 1 +A°'B°)sC 1 

from which the table is written : 



A 


B 


c 








1 





1 




1 







1 


1 


1 



A 


B 1 


c 





G 


1 





1 





1 








1 


1 


1 



0°s appearing in all unfilled positions.. Similarly, directions 
for the printing of G's are also sufficient and may result in 
simpler descriptions in some cases. For example, 

A 0o B°sC and (A 1 B°+A 0o Aa*$ jC 1 

both describe the same machine o 

We will say that two cells, C and D, are equivalent if C holds a 
"1" whenever D holds a n l m and C holds "0" whenever D holds "0" . 
Thus, from a table, eog.^ 



A 


B 


c 


D 


E 








1 


1 








1 











1 











1 


1 


1 


1 


[ 1 


1 
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it is seen that C is equivalent to D and E is equivalent to A< 
These will be written C=D and E=A, respectively. 



Thus, given 



x 1 :* 1 



X 


f 








1 


1 



it is seen from the table that x=f <> This could have been obtained 
from the statement x 1 : f i by dropping superscripts and replacing 
H s H with "=*% and the converse is of course also true. Using this 
rule, we would also obtain x°=f° from x°jf°. 

From x°sf a we would obtain f=x°. The table is: 



x 


f 





1 


1 






Inspection of the table shows that the symbol in cell f is the 
complement of the symbol in cell x, i„e«, f«complement of x. 
Thus, x° will be read w x complement" or "complement of x M , the 
superscript "o" indicating the complementation « 



Prom 



xQ-.f 1 



X 


f 


g 





1 





1 





1 



we conclude that x = (x°) , the double -complement rule. 

Now we define two cells 1 and in the following way: Cell 1 
always holds the symbol "1" (see, for example, cell Ei of the UM 
described earlier) and cell always holds the symbol "0". Evi- 
dently? 

1° = and 0° = 1 



Consider the following printing statements for cells fj_ through fgj 

(i^l 1 ):* 4 
(l 1 +0 1 ):f, 1 

(C^+O'jsf/ 

I 1 -l 1 ;^ 1 



l x »0 x :f, 

O^oSfJ 



The table of combinations is then 
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I 





£» 


£ z 


f 3 


f * 


f 5- 


f 


1 





1 


1 





1 








1 





1 


T_ 





1 








1 





1 


1 





1 








1 





1 


1 





1 





. 



from which we conclude that 



1+1=1 


1*1=1 


1+0=1 


1-0=0 


0+0=0 


0°0=0 



These results illustrate properties of an arithmetic which is like 
ordinary arithmetic for the '"dot" operation (multiplication) but 
unlike ordinary arithmetic for the "plus" operation (addition). We 

have described the fundamental operations of Boolean Algebra . 

Evidently these operations are commutative, i.e.,' "x or y" is the 
same as "y or x" and "x and y" is the same as "y and x" Symbolically 



x + y -• y + x 



and 



x»: 



= yx 



The "and" and "or" operations are also a ssociative ,. Using the 
parenthesis to denote grouping, the following statements hold: 



x + (y + z) - (x + y) + z 



an 



d x«(ys) = (x»y)-z 



Consequently j, the order and grouping of symbols in any Boolean ex« 
pression is arbitraryj*" The distributive properties of the "and" 



and or operations can be established by constructing the table 
of combinations for the forms! 



(x* • yi+x 1 «z 1 )sf | 1 
x 1 •(.y 1 ^ 1 )sf* 



x 



I 


















1 





1 


1 





1 





•1 

X 


1 


1 


1 



(x 1 ry 1 oz*):fi 





f 2 


t 3 



































1 








1 


1 


1 


1 


1 


1 


1 


1 


1 


1 



Comparison of columns in the table shows that f , =f 2 and f 3 =f ^ , i.e., 

x»y+x«y ~- x»(y+z) and (x+y)°(x+z) -• x+y*z 

As in ordinary algebra, then, one can "multiply" through a "sum" 
(recall the process of " factoring 8 )» Unlike ordinary algebra > 
Boolean algebra permits one to "add" through a "product". These 
forms will occur quite often ia. subsequent work<, 
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Abstract: Theorems itf Boolean algebra can be proved by 

constructing a table of combinations for given 
expressions and finding equivalent entries in the 
table* The manipulative character of the algebra 
makes possible the proof of additional theorems 
without recourse to a table of combinations. 
Certain expressions are dual in form to one another. 
Examples : 



x 



+ 1 = l] 
x*0 = Oj 



x + yz = (x + y)(x + z) 
x(y + z) = xy + xz) 



Boolean algebra is also related to statements 
about paths in networks ■> A path between two nottes 
in the network can be associated with the symbol 'l 1 
and the absence of a path with the symbol '0*. A 
typical Boolean expression and its network repre- 
sentation follows: 



x 



y 

z 



X'(y + z) 
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By using the general process of writing out the table of combina- 
tions for various expressions and then comparing columns to find 
equivalent forms, the theorems of Boolean algebra can be developed. 
As further examples, consider the following expressions: 



(«' 



+ x 



x*-* 1 : ti 



X 


fi 


fa 











1 


1 


1 



Examination of the table shows that f{ = f z = x, i.e., 

X + X = X 

X»X = X 

and hence, by continuation 



x + x + 
x°x» . 



+ x = x 

•X a X 



Similarly, the expressions 
(x 1 +l i ):ff 



x^l^ff 



lead to the conclusion that 






1 


X 


* 


u 


'*j 


U 





1 





1 














1 


1 


1 


i 


1 






x+1 = 1 
X»l = X 



x+0 = x 
x«0 •« 



Hot ice that with the exception of the first one, these forms are 
like those of ordinary algebra. 



X 


f l 


\ 





1 





1 


1 






Finally, from the expressions 



we conclude that 

x+x° - 1 
x-x° = 

Additional theorems can also be obtained from the ones already es- 
tablished without recourse to a table of combinations. For example, 
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it can be shown that 

x + x-y = x 

by using the first of the distributive properties already proved: 

x + xy = x»(l + y) 
= x.(l) 
= x 

Similarly, it can be shown that 

x + x°y = x + y 

by using the second distributive property : 



32 



x + x°y = (x + x°)°(x + y) 
- (l)-(x + y) 
= x + y 



The advantages of the manipulative character of the algebra in the 
above examples are apparent . 



The theorem of DeMorgan relates an expression and its complement. 
Consideration of the forms? 



(x*+..y 1 ):fj 

xQ«y°2f2 



X 


y 


fi 


fa 








1 


1 





i 








1 











1 


1 









leads to the conclusion that since f ± = (f°)Pand f 4 = f & , 

(x + y)° = x 0o y° 

This can be extended to expressions involving more variables by using 
the associative property in the following ways 

{x + y + zj° = (x + (y + z))° 
= x<My + z)° 
« x° o y G °z° 

A more general form of DeMorgan's theorem is the following: 



f \ X j, f X £> eoo Xqj " , +) — f\X^, X^J 



x 



o 



) 



that is, the complement of an expression involving certain variables 
and the "dot" and "plus" is obtained by replacing each variable by 
its complement and interchanging the "dot" and "plus". For example: 

(x + y.z)° - x°-(y© + z°) 
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PROBLEMS 



3.1 Show that the complement of any Boolean function may he ob- 
tained by complementing all of the function variables and 
replacing "•" with -?■+" and "+" with "•".. That is, show that 

£°(<H> x a> ••• x n> >-+) 

= ±{x^ } x^y ♦ • • x n , + f * ) 

3.2 Find the complements of the following functions: 

f = ab + cd 

f = (a + b)(c + d)(b° + d) 

f = (ab°c + bc°d)° + a° 

Check the results by showing that f -f° = and f + f ° = 1 
for each function. 

3.3 Prove the following: 

xy + x°z = (x + z)(x° + y) 
xy + x°z + yz = xy + x°z 
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Duality 

Using DeMorgan's theorem one can obtain new theorems from those 
already proved. For example, consider 

x(y + z) = xy + xz 

the first distributive property theorem. Complement both sides of 
the identity? 



(x(y + z)}° = {xy + xz}° 

x° + y°z° = (x° + y°)(x° + z°) 



which is recognized as the second distributive property theorem 
applied to complemented variables. Consequently, the two distri- 
butive theorems are related to each other > we say that they are 
dual in form to one another. For any Boolean expression/ a dual 
expression can be obtained by complementation of the expression 
followed by complementation of all variables. For example ' 

X+X«X 

Complementation of each side gives 

(x + x)° = x° 
x°-x° » x° 
and final complementation of all variables yields 

X*X = x 
as the dual expression. Other expressions and their duals follow: 

X + 1 = 1 1 X + X° ss l J 

x°0 = OJ x«x° = Oj 

x + xy = x 1 x + x°y = x + y ) 

x(x + y) = xj x(x° + y) = xy J 



Venn Diagram 

Another way of visualizing the expressions of Boolean algebra is to 

relate the states of cells to abstract areas. The area inside the 

following closed figure represents the state in which cell x holds 

*1 9 and the remaining area represents the state in which cell x 

holds »0«s 

,o 
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By overlapping figures of this kind we obtain a Venn diagrams 5 ) f 
Boolean expressions of the cells involved. For two variables, the 
Venn diagram is the following; 




By relating the four distinct areas one can establish the theorems 
of Boolean algebra for two variables. For example, by joining the 
region x*y to the region x°y, one obtains the region x. Symbolically: 



x-y° + x«y = x 



Extension of the technique to more variables is, of course, possible. 



Network Representation 

The relationships of Boolean algebra can also be applied to state- 
ments about paths in a network of interconnected nodes. '" k The 
following definitions are used: 

?• x 1 o Q 

will mean "there is a path from P to Q if x holds '1' and there is 
no path from P to Q if x holds *0'. Similarly 



Q 



will mean "there is a path from P to Q if x holds '0* and no path 
if x holds , l , . n Then the following correspondences hold: 

1 

po 1 o Q <~>Po— _ cQ 

P . o Q & P <» — °Q 

so that a path is associated with the symbol '1* and the absence of 
a path is associated with the symbol '0'. 



5 H. Venn, Symbolic Logic , l88l 

"C. E. Shannon, A Symbolic Analysis of Relay and Switching Circuits , 
Transactions of A.I.E.E., Vol. 57, 1936. 
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The relations "and" and "or" can be represented as follows? 



36 



x 



y 



■Q 



x-y 
,1 



x* 



Q 



x + y 

In the first case, there is a path from P to Q only if x holds •l' 
and y holds 'l 8 . In the second case, there is a path from P to Q 
if x holds 'I s or if y holds «1' (or both). 

The theorems of Boolean algebra can then be represented as equiva- 
lence relations between suitable networks. Some of the theorems 
and their network representation follow (l's superscripts and node 
labels will be dropped) : 



■x 



X 



x°x 



X 



CI 



X + x = X 



X- 



X + 1 = 1 



O X X® O as O- 

X'X°= 



-X v 



X + X9 a 1 
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^x y 

-x z- 



x»y + x°z * x(y + z) 



y — z 



+ y°z = (x + y)(x + z) 



x — y- 



x u — z 



y— z— J 



< ' ' o 



CA J 
' 



xy + x u z + yz = xy + x u z 



1— W X 



-y — z 



, p w n_r X ~\-T w ~f-T x ~~i . 

L y I I y I L z I I z I 



wx + yz = (w + y)(x(+ y)(w + z)(x + z) 



For a more complete description of the application of Boolean 
algebra to the synthesis and simplification of networks of this 
kind, the reader is referred to the texts 



Keister, Ritchie, Washburn, The Design 
of Switching Circuits , Van Nostrand, 1951. 
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*7 





1 





1 





1 









p- 




p°.q.o 



k 
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The four Boolean functions of one variable are defined by the 
following tables 



X 





(x)° 


X 


1 








1 





1 


1 








1 


1 



Any Boolean expression involving only one variable must reduce 
to one of these four forms regardless of its apparent complexity. 
Examples s 

(x +(x)°)° + x°°(x°x°x + x) = 

(((((x)°)o)o)o)o = (x) o 

Design a Turing machine which, when supplied a tape bearing any 
Boolean expression involving one variable, will print the correct 
reduced form of the expression. The symbols appearing initially 
on the tape ares 



x, 



{, ), =, * 



Parentheses will always be written explicitly with any complement; 

(x)° instead of x° 
and "•" will always be written explicitly between factors 

x«(x + x°(x)°). 

The expression is written one symbol to a cell and terminates with 
the symbol "="$ all other cells are blank (symbol "b^). For example, 
the last expression appears as 



.-.-■b. 



( 



x 



x 



) 



The machine starts in state 1 scanning the cell which holds "=" and 
is to print the correct reduced form on the cells immediately 
following the "=" symbol* Any additional symbols may be used but 
must be erased upon completion. 



6M-3938, S^ 



39 



SYNTHESIS OF BOOLEAN MACHINES 

The Boolean algebra description applies quite generally to two-symbol 
machines which manipulate information in several cells simultaneously 
according to fixed rules.* We will call these machines Boolean ma - 
chines wT and will now consider their synthesis and logical structure. 

The simplest significant Boolean machine is a one-state, one-cell 
structure. In the more interesting cases, it is a complex machine 
with many internal states and many peripheral cells. What is desired 
in synthesizing these more complicated machines is a graphic descrip- 
tion which emphasizes the logical relationships between the cells of 
a given machine and which thus augments the state and transition diagram 
describing the action of the machine . We will now proceed to make more 
explicit the possible forms of these logical relationships. 

Two -Cell Machines 

Consider first the one-state machine in which the printed symbol de- 
pends on the symbols initially held in two cells, p and q: 



p 






H 






« 

* > 


<v 











Sixteen different machines are possible) they are described by the 
16 Boolean expressions, f Q , f , , . », f ls , enumerated in the following 
table of combinations % 



p q. 


fo 


*\ 


*a 


fs 


u 


** 


f« 


f T 


*8 


*s 


f,o 


f.. 


f« 


f,3 


f 


f .s 








1 





1 





1 





1 





1 





1 





1 





1 


1 
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1 
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1 
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1 








1 


1 


1 














1 


1 


1 


1 
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1 
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1 


1 1 
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1 


1 


1 


1 


1 


1 


1 



It is noted that f n = and f 



15 



I* The Boolean expressions can be 



obtained by writing out the terms involving p and q which give rise to 
"l's" in the table; 



*Refer page 27. 

'I. S. Reedt "Some Mathematical Remarks on the Boolean Machine," 
Project Lincoln Technical Report #2, Dec. 1951 
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f = f 8 = p-q. 

f , = p°-q° f 9 = pO.q.0 + p.q 

f z = p°.q f , = p°.q + p-q 

f 3 = po.^o + p o. q f|( = po.^o + p o. q + p . q 

f 4 = p-q° f (2 = p.qo + p . q 

f i- = P°-q° + P-q.° f , 3 = P°-q.° + P e( l +.P-CL 

f 6 = pO #qL + p.^o f ^ = p o. q + p.^o + p .q_ 

f 7 = po.qo + p o oC1 + po^o f)5 = i 

Many of these expressions can be simplified. For example: 

f 3 = po-qo + p o. q 

= P°(q.° + q) 



= po 



and 



f 7 =.p°-q° + p°-q + p-qP 

= p°(q° + q) + p-q° 

= p° + p-a° 

= (p° + p)(p° + q°) 

= po + qO 

If these reductions are carried out for all such cases, the following 
list of minimum forms is obtained: 



?0 = 





f « 


= pq° + p°q 


f i. 


= 


P° + q 


f, = 


P°q° 


f 7 


= p° + qO 


f 12 


= 


P 


*2 = 


p°q 


*8 


= pq 


f|3 


= 


p + q° 


f 3 = 


P° 


f 9 


= p°q° + pq 


f |i|. 


= 


p + q 


*4 = 


pqO 


f.o 


= q. 


*w 


= 


1 


*5 = 


qO 
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The transition diagram for any of the one-state, two-cell machines 
can be obtained directly from this list» For example, the machine 
described by f 7 , M 7 has the diagrams 




In order to represent the logical relationships 



p° + q° 



and 



,p° + q. 



O^O 



= p°q 



for M 7 in terms of the cells p and q in a graphic construction, we 
will introduce a symbolism based on the table of combinations. Note 
that the table for f 7 can be drawn in either the form: 



p 


<1 


*7 








1 





1 


1 


1 





1 


1 


1 






Or. the matrix form: 



q. 



*v 





1 





1 


1 


l 


1 






The four positions in the matrix form can be related to the quadrants 
of a circle. Thus/ the expression f 7 might be represented by a 
connective element of the following sort\°^? 



P 

<1 




f 7 = p° + q° 



the marks in the 1st, 2nd, and 3rd quadrants corresponding to the 
position of l 8 s in the matrix form for f 7 • A few other examples 
will help to illustrate the use of this symbol: 



f, 


1 




1 


1 





f » - P°-q° 



8 



J. D. Goodell: "The Foundations of Computing Machinery, " journal 
of Computing Systems, Vol, I, Ho. 1, June 1952. 
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f 6 





1 








1 


1 


1 






P' 




f 6 = p°°q. + P 9( l 



f 

x 15 


1 




1 


1 1 

1 1 



<1 



-# 



f ... = 1 



Using this symbol we can now construct any one -state, two-cell, binary 
machine in terms of the cells themselves and describe the action of 
the machine by means of the associated transition diagram. For 
example, the machine described by f r iss 



& 



:<t' 




:r 



<VW)fH 



M. 




and the machine described earlier (page 27 )> which corresponds to f 9 , 
is represented by; 







^■(O 


re' 


:c° 


c 






s 


c^ 








.s 


J 


fast 


+ A°.8 ):C' 

















The remaining lk machines of this class can be constructed in a similar 
manner using the appropriate connective elements., 

Universal Connective Elements 



It is possible to put each of the expressions f Q > f | > • « • f | 5 into 
a standard form which corresponds to that of f , , namely the form: 
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or its equivalent 



) + \oooooj 



where the empty parenthesis groups contain only combinations of the 
letters p and q which are also in the standard form. For example, 
f*f = p + q can be written 

fj* = \ i(p + ^r - 



[[(p + o°] + l> + ^) ]) 



Similarly, each of the sixteen expressions can be written in a form 
which corresponds to that of f 7 



( oooao )° +' 



or its equivalent 



f? 



Again as an example ^ tjj = p + q would be written 

tM - [(P)° + (P) I1 + [U) + (4)°]° 

These expressions, £• and f y , are known as the Sneffer stroke 
functions^, and are sometimes written f \ = p f q and f y - p j q. 
The existence of these standard or universal forms means that any 
of the Boolean machines, M , Mi, . . . M^5 can be synthesized using 
only the connective element for fj 

fi = (p'+ a) - P°»q° 




or the connective element for f 7 




f ? = (p-q.)° = P° + q C 



Accordingly, these elements might be called universal connective ele - 
ments . To demonstrate this universality of these elements, we will 
now proceed to show how the ^jLxteen machines Mq, M, . . • . M, y are con- 



%. M. Sneffer: "A Set of Five Independent Postulates for Boolean 
Algebra," Trans . Am.' Math. Soc. XIV 1913 
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struct ed using only the element f , , and then we will show that any 
structure involving only f j can be replaced "by another structure 
involving only f 7 . This demonstration is essentially the same as 
that presented by Goodell^o 

First, the sixteen forms are synthesized as follows : 



*o 


= 


( 


7\ 




p 

a- 


\ 


■P 








f l 


= p°< 


q° 






p 

<1- 


< 


"M 




V 








?2 


= P°< 


<1 






P" 


< 


?V 




-? 




(p° + p)° = 




P°»q.° = (p + q)° 



** = P° 




-A (P + q°)° = P°-qi 




p , — i + 




P 



f 4 = P 0( 1 C 





(P° + q)° = p-q C 



10 



J. D. Goodell.: "The Foundations of Computing Machinery, Part II," 
The Journal of Computing Systems, Vol* 1, No» 2, January 1953. 



6M-3938, S^ 
P- 





^ 



f, = p-QL + p°.q 




0,^0 



f 7 = p u + q ( 




fg = P ,( l 
P- 

q.- 




f = p-q + p°-q° 



P 

q.- 




f 10 = 1 



p- 
q. 




L io 





* f •■ 




-saftK^w: 




tf 



^Cp+qXpS+qO) 

= pq° + p°q 



pO+q° 



(p°+q°)° 

=p.q 



u — ' qj = (p°+q)(p+<t°) 



p r . \ (PtqQ 



— *\ * I 




•ptpV 
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f „ = p° + q 




f u = P 



p. 
q 




f„ = p + q° 



P. 

q 




f H = P + q 



ii 



13 



P 



-^m^ 



46 



P u +q 



rf^ 



P+T 



p — 


^ 


_f„ 


= 


P 


q 


r 






q 




p+q 



f =1 

1 15 - 1 - 



P- 




ir 



-^f^^-s» 



The corresponding 16 two-cell Boolean machines can be drawn directly 
using this list of f , -synthetic forms. For example , the machine M |lf 
is: 



p 


rr' 


s 






M 



w 
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Finally, any structure involying f can be replaced by a structure 
involving fy according to the following synthesis? 

f t = p°oq° 



hi 




f = p 



-£^3^ 




-p°-qO 



Hence, f , and f 7 connective elements are both universal for two-cell 
Boolean machines.. 

Although we will not make use of the universal properties of either 
element in subsequent work, it is of interest to note that the 
physical realizap'ility of any Boolean machine can be established by 
snowing that it is possible to construct a device which implements 
either f , or f 7 . 



Boolean Machines Involving N Cells 

In discussing the synthesis of machines involving an arbitrary number 
of cells, it is convenient to define generalized connective elements 
for the "and" and "or" 'expressions. The circular symbol for the two- 
cell expressions can be generalized to more than two cells, but the 
drawing of matrices of more than two dimensions is difficult. By 
grouping two terms together at a time, the expressions for "and" and 
"or" involving N cells can, of course, be constructed using only the 



connective elements f . and f 



n 



respectively: 



x 



x 



■ = <£-Q--0 



X, •X E 'X 3 . . . 



•x N 



X. 



% 
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x, 



X. 



X, 



X, 



~Q-Q-'--Q 



■k8 



Xi t X « "t- X «* t «>oo t X«t 



However, the connective elements we shall use in subsequent discussions 
of Boolean machines, regardless of how many cells are involved, are the 
following: 



x, 



x. 



X N- 



X. "X, ... °x 



•I ^2 



N 



X.£ 9. 



X 



z *- 



C N 



X t T X 2 » • 



. + X; 



N 



and, to complete the set of connective elements, a complementation 
element will be drawn in the following manner: 



> o 



■*► x v 



A composite example will illustrate the symbolism: 



A— 

B — 



•M + 



-* o 



-> o 



r- — *• 



A*B*C + A°-B°-C° 



i* 



■>(ABC + A°B°C ) => (A°+B°+C°)(A+B+C) 
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Extension of this symbolism to any Boolean expression follows from the 



definitions and from the fact that 
set of connective elements. 



'+' and ,0f form a complete 



The Time Element 

It is necessary to make the distinction between printing a symbol and 
holding a symbol more precise . Printing o ccurs at definite times, 
namely those times at which transitions from state to state occur. On 
the other hand, symbol holding is a situation which persists in time 
until a new symbol is printed. For example, suppose cell A holds the 
symbol 8 0' and that during a machine transition occurring at time t]_ 
the symbol s l 9 is printed on A. We might represent the history of cell 
in the following way: 



A 



• 









• 


i 


k» time 


— >— 



To make the idea of transition timing more precise, we will introduce 
a new component cell into the machine. This new cell, which will be 
labeled P, will act as a clock for the rest of the machine. It will 
have the property of holding the symbol '1' when transitions are to 
occur and the symbol 8 0' otherwises 



1 - 



P 







£h- 



time 

>- 



It is assumed that transitions and printing require a finite length 
of time and, consequently, P will hold '1' for a finite interval, 
although one which is not large compared to the interval between 
transitions. We will say that P acts as a source of pulses , and 
that a cell such as A is a source of symbol levels . 

Printing can then be specified by forms of the following sort: 

P^-'A^B 1 

P 1 '(A 1 + B 1 )^ 1 

so that the act of printing is confined in time and coincides with 
the pulses occurring at t]_, tg> «tc„ For example: 
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A 



P-A 



time 



P^A^B 1 



In the case illustrated on the left, A holds '0' and no change of 
symbol occurs on B. In the case on the right, A holds '1' and a 'l 1 
is printed on B during the transition event. 

A refinement of the cell symbol will simplify drawing and emphasize 
the distinction between printing and holding functions. The cell 
label is written within the element representing the cell, and one 
half of the element is associated with the symbol '1' and the other 
with '0 1 . 



Then printing can be represented by one of the two forms: 



© 



A 







B 



:A^ 



:B J 



A connective element will be associated with the appropriate sides 
of the participating cells. For example, the machine P^-A-^B :^ 
is drawn: 
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C 





















, | 











A 


1 




' 


B 


1 





5 



© 



j 



A'.B°:C' 
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The arrowhead will be used to denote symbol pulses and the diamond 
to denote symbol levels . One more example will illustrate these 
forms o The machine used to introduce Boolean algebra (page 27) is 
represented by the following drawing: 




(A^B 1 + A^B )^ 1 
(A^B + A^B 1 )^ 



C omplement at i on ...... 

A case of special interest is that in which a cell participates in a 
symbol-printing operation on itself, e.g., the complementation operation: 

,c 



P^A^A 



P^A^A 1 



:A V 
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To avoid a logical indeterminacy it is necessary to redefine the 
printing operation so as to include a delay between the time at 
which the printing pulse occurs and the time at which the cell holds 
the printed symbol: 




Complementation structures can then be simplified according to the 
following schemes 



1 

A" 

I I • k 



:A V 



1 
A 



© 



where the pulse line drawn to the center of the cell element will 
indicate the complementation directly , As an example, the machine 
A^B is 



1 
B 



1 
A 
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The existence of the printing delay also permits the construction of 
machines in which the symbols held in a set of cells are simultaneously 
interchanged. For two cells, A and B, an exchange of symbols is ac- 
complished by the following structure; 





Interchange structures involving more cells may take many forms. 
A shifting structure is obtained if cell A's symbol is printed on 
cell B5 B's on C| C's on D, etc. If the symbol in the last cell 
in this set of cells is printed on the first cell, a cyclic inter - 
change is obtained and the set of cells takes the form of a closed 
ring. 
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Machines Involving Serial States 

The Boolean machines discussed heretofore have all been one -state 
machines . We will now extend the synthesis procedure to machines 
involving more than one state. 

Consider the following two-state machine, M: 




M starts in state 1 and prints a '0' on B in the transition to state 2 
From state 2, a '1' is printed on B if A holds '1' and M returns to 
state I, no change in symbol occurs on B if A holds '0'« The net 
effect is that the symbol finally appearing in cell B is the same as 
the symbol in A$ in other words, the symbol in A is transferred to B. 

Evidently the printing requirements would be met if M supplied addi- 
tional levels according to its state: 



Sw>a"oe J. 



O 



J 



1 

A 



j$$&§LmaL 



o 
o 



IS 



1 

B 



j 
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Complete Configurations 

In one sense, cell K of the preceding section controls the action of 
the machine, M^ in dealing with cells A and B. In another sense, 
cells K, A, and B are simply undifferentiated cells of a three -cell 
structure which is capable of assuming 2T = 8 stable configurations 
and which jumps from one configuration to another in a manner which 
depends only on the current configuration itself. Thus, if the eight 
possible arrangements of symbols in K, A, and B are assigned config- 
uration numbers according to the table: 



K 


A 


B 


# 




















1 


1 





1 





2 





1 


1 


3 


1 








k 


1 





1 


5 


1 


1 





6 


1 


1 


1 


7 



then the action of the three-cell structure is described by the 
following transition diagram in which the nodes represent not states 
of K, but complete configurations °„ 









6V 



® 



Note that the transitions in this kind of diagram are unconditional 
and that the final configuration depends only on the initial config- 
uration . From the fact that M starts in state 1 (K°), it follows 
that the complete structure starts in one of the four configurations, 
0, 1, 2, or 3, depending on the initial arrangement of symbols on A 
and B. Consequently, the structure can never assume configurations 
5 or 7? this can be seen from the configuration transition diagram. 



It is worth mentioning at this point that in any physically realizable 
machine there always exists the chance that spurious transitions will 
occur o It might be said that one of the principal problems in engin- 
eering such a machine is that of making the probabilities of these 
spurious transitions suitably small. 
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A General Synthesis Procedure 

Given the transition requirements for any structure in terms of complete 
configurations, it is possible to synthesize a suitable machine having 
the required transition diagram. As an example, suppose that it is 
desired to synthesize a machine which has the diagram; 



i-KD — ><D *© -©- 



The minimum number of two-symbol cells required is log 2 ^ = 2 5 these 
may be designated K and Ki . lext, the state numbers 1, 2/3, and h 
are coded in terms of the symbols in K and K A « The choice of code 
•*- s completely arbitrary , The code we will choose for this example 
is the following: 



K i Kq 



# 

1 
2 

3 
k 



We next write the Boolean expressions which will produce the required 
transitions . Consider first the situations which result in the print- 
ing of the symbol "1' on K QO This occurs in the transition 1 » 2 
and again in the transition 2— -»~3 The configurations which lead to 
the printing of a "1/ on Kq are thus 1 and 2, and we may write: 






+ K< K n );Kr 



In a similar manner, the remaining printing expressions can be obtained, 
They are: 

P^K^Kq- + KJ°Kg):Kg 
P*»(Kj B K + K^ °K )sKjl 
P*.(K?-K§ + K}»K8):K? 
These may be further reduced by factoring: 

P A -K?-(K8 + 4)sk£ P 1 -* ^ 

^•Kj-tKg +K ):K§ l4-xJ:Kg 

P 4 -Ko'(KJJ + k}):kJ P 1o K^:k| 

P 1 'K8°(k5 + k1)sKJ P i »K8sK° 
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The required structure is thus 



10 1 

i "■ 







A A 



o 1 

Ko 



♦ JO- 
S' 



TS 



r*Q — Ks> — *® — ^>—\ 

00 01 11 10 



The device, by definition, "counts" up to the number k and then starts 
over at 1. 

A second example of the general synthesis procedure again deals with' 
cyclic counting &nd with a coding scheme of special interest . First, 
a machine which counts cyclically through the numbers through 7 "will 
be synthesized, and then the results of the synthesis will be general- 
ized to larger rings • 

The eight configurations require three cells? Kg, %, and 'ftp. '^ ne 
particular code chosen will be a binary numerical code in which the 
configuration number is a sum of powers of 2, 21 "being the contribution 
to the sum of Ki holds a ' 1 ' : 



6M-3938, S5 



59 



K 2 


Kl 


K 


# 




















1 


1 





1 





2 





1 


1 


3 


1 








h 


1 





1 


5 


1 


1 





6 


1 


1 


1 


7 



Again, any consistent, complete coding scheme could have been 
chosen. The particular advantage of a "binary numerical code is 
that it will yield a simple , iterative structure for the synthe- 
sized machine. 

Instead of proceding as "before, we will note instead the configura- 
tions which lead to changes of symbols C 11 ) 

We note first that K is complemented during all transitions. We 
have immediately; 

P 1 ; KS 



iv 



O 







"CD — i 

i 



K^ is complemented during transitions from the configurations 1, 3> 
5, and 7:. 

P^CK^KiKo + K°k}k£ + k!k?k£ + 4KiK )sKj 



which factors to 



P °Ko e (K°K? + k£k{ + KjK + 4Ki)sKf 



i^o . J. A 



11 



Jeffrey, R. C, Reed, I. S.s "The Use of Boolean Algebra in Computer 
Design o" MIT Digital Computer Lab, Engineering Note E-^5^-2, 
15 April 1952. 
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and, since the expression within the parenthesis is the same as 1> 



( P l >Ko 



1 

Ki 



I 



ff 



^ — <► 







Kr 



UD 



— **©~ — KD — KD — KD" 

00 01 10 11 



Finally, K 2 is complemented during transitions from configurations 
3 and 1% 



P 1 -(K°k}k£ + kJ4Ko)'K£ 



or 



p^ki-KoXkI + k!)^ 



P*«kJ'kJ :K' 



^•K&JkJ 



1 

K 2 



I 



• ^ — ?■ 



(P 1 )^ 



1 








Kq 



1 








000 



5>-KD— KD— *-©— KD— -<z> 

010 011 100 101 110 111 
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The generalization to structures involving more stages follows im- 
mediately : 

The i th stage is: 










Ki 



P 1 (Ki.i-4_ 2 '....-K ):Ki 



Iterated structures of this kind are desirable from the standpoint 
of simplicity of physical construction. 
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PROBLEMS 



5«1 Design a one-state machine which will accomplish 

a cyclic interchange of symbols on the three cells, 
A, B, and C 



A 1 jB 1 



C-^A 1 



B^C 1 

A°;B° B°;C° C°;A° 

using only the complement printing operation. 

5.2 Design a machine to perform a cyclic interchange 
on A, B, and C as in 5-l> hut with cells which do 
not include a printing delay. How many state are 
required? 



5.3 Construct a two-cell, four-state machine which has 
the following transition diagram: 




